热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

侧边|篇文章_带你实现开发者头条实现左滑菜单

篇首语:本文由编程笔记#小编为大家整理,主要介绍了带你实现开发者头条实现左滑菜单相关的知识,希望对你有一定的参考价值。今天开始模仿开发者头条的侧滑菜单,

篇首语:本文由编程笔记#小编为大家整理,主要介绍了带你实现开发者头条 实现左滑菜单相关的知识,希望对你有一定的参考价值。


今天开始模仿开发者头条的侧滑菜单,是本系列第二篇文章,相信大家已经看到很多app使用这种侧滑。今天我来教大家用android自带DrawerLayout控件实现。

DrawerLayout是SupportLibrary包中实现了侧滑菜单效果的控件,可以说DrawerLayout是因为第三方控件如MenuDrawer等的出现之后,google借鉴而出现的产物。DrawerLayout分为侧边菜单和主内容区两部分,侧边菜单可以根据手势展开与隐藏(DrawerLayout自身特性),主内容区的内容可以随着菜单的点击而变化(这需要使用者自己实现)。


一.先上效果图:


二.代码实现

1.drawerLayout其实是一个布局控件,跟LinearLayout等控件是一种东西,但是drawerLayout带有滑动的功能。只要按照drawerLayout的规定布局方式写完布局,就能有侧滑的效果。我这边把侧滑菜单的内容放一个布局文件了。

<android.support.v4.widget.DrawerLayout
xmlns:android&#61;"http://schemas.android.com/apk/res/android"
android:id&#61;"&#64;&#43;id/drawer_layout"
android:layout_width&#61;"match_parent"
android:layout_height&#61;"match_parent" >

<RelativeLayout
android:layout_width&#61;"match_parent"
android:layout_height&#61;"match_parent"
android:clipToPadding&#61;"true"
android:fitsSystemWindows&#61;"true" >

<include
android:id&#61;"&#64;&#43;id/rl_title"
layout&#61;"&#64;layout/layout_main_title" />


<FrameLayout
android:id&#61;"&#64;&#43;id/content_frame"
android:layout_width&#61;"match_parent"
android:layout_height&#61;"match_parent"
android:layout_below&#61;"&#64;&#43;id/rl_title"
android:background&#61;"&#64;color/white_normal" >

FrameLayout>
RelativeLayout>

<FrameLayout
android:id&#61;"&#64;&#43;id/left_drawer"
android:layout_width&#61;"280dp"
android:layout_height&#61;"match_parent"
android:layout_gravity&#61;"start" >


<include layout&#61;"&#64;layout/layout_main_left" />
FrameLayout>
android.support.v4.widget.DrawerLayout>

注意事项
主内容区的布局代码要放在侧滑菜单布局的前面,这可以帮助DrawerLayout判断谁是侧滑菜单&#xff0c;谁是主内容区
侧滑菜单的部分的布局&#xff08;这里是ListView&#xff09;可以设置layout_gravity属性&#xff0c;他表示侧滑菜单是在左边还是右边。

2.MainActivity.java 继承FragmentActivity
1).设置内容Fragment&#xff0c;设置状态栏
2).处理左侧点击事件,在点击事件中设置选中背景&#xff0c;关闭左边侧滑菜单。

public class MainActivity extends FragmentActivity
private DrawerLayout mDrawerLayout;
private RelativeLayout rlHome, rlGift, rlShare;
private int currentSelectItem &#61; R.id.rl_home;// 默认首页
private ContentFragment contentFragment;
&#64;Override
protected void onCreate(Bundle savedInstanceState)
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mDrawerLayout &#61; (DrawerLayout) findViewById(R.id.drawer_layout);
findViewById(R.id.iv_menu).setOnClickListener(clickListener);
initLeftMenu();//初始化左边菜单
contentFragment&#61;new ContentFragment();
getSupportFragmentManager().beginTransaction().add(R.id.content_frame,contentFragment).commit();
setWindowStatus();

private void initLeftMenu()
rlHome &#61; (RelativeLayout) findViewById(R.id.rl_home);
rlGift &#61; (RelativeLayout) findViewById(R.id.rl_gift);
rlShare &#61; (RelativeLayout) findViewById(R.id.rl_share);
rlHome.setOnClickListener(onLeftMenuClickListener);
rlGift.setOnClickListener(onLeftMenuClickListener);
rlShare.setOnClickListener(onLeftMenuClickListener);
rlHome.setSelected(true);

private OnClickListener onLeftMenuClickListener &#61; new OnClickListener()
&#64;Override
public void onClick(View v)
if (currentSelectItem !&#61; v.getId()) //防止重复点击
currentSelectItem&#61;v.getId();
noItemSelect();
switch (v.getId())
case R.id.rl_home:
rlHome.setSelected(true);
contentFragment.setContent("这是首页");
break;
case R.id.rl_gift:
rlGift.setSelected(true);
contentFragment.setContent("这是礼物兑换");
break;
case R.id.rl_share:
rlShare.setSelected(true);
contentFragment.setContent("这是我的分享");
break;

mDrawerLayout.closeDrawer(Gravity.LEFT);


;
private void noItemSelect()
rlHome.setSelected(false);
rlGift.setSelected(false);
rlShare.setSelected(false);

private OnClickListener clickListener &#61; new OnClickListener()
&#64;Override
public void onClick(View v)
switch (v.getId())
case R.id.iv_menu:// 打开左边抽屉
mDrawerLayout.openDrawer(Gravity.LEFT);
break;


;
// 设置状态栏
private void setWindowStatus()
if (Build.VERSION.SDK_INT >&#61; Build.VERSION_CODES.KITKAT)
// 透明状态栏
getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
// 透明导航栏
getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_NAVIGATION);
// 设置状态栏颜色
getWindow().setBackgroundDrawableResource(R.color.main_color);


3.左侧菜单item选中背景的布局文件 selector_left_menu_item.xml。


<selector xmlns:android&#61;"http://schemas.android.com/apk/res/android">
<item android:drawable&#61;"&#64;color/menu_left_item_select" android:state_selected&#61;"true"/>
<item android:drawable&#61;"&#64;color/white_normal"/>
selector>

4.ContentFragment 显示内容的Fragment 这里我加了一个设置内容的方法&#xff0c;就是用来点击左侧切换显示用的。

public class ContentFragment extends Fragment
private TextView tvContent;
&#64;Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,Bundle savedInstanceState)
View rootView&#61;LayoutInflater.from(getActivity()).inflate(R.layout.fragment_content, null);
tvContent&#61;(TextView) rootView.findViewById(R.id.tv_content);
return rootView;

public void setContent(String content)
tvContent.setText(content);

5.drawerLayout与Fragment是什么关系&#xff1f;
我们看到很多使用drawerLayout的代码中都同时使用了Fragment&#xff0c;这会造成误解&#xff0c;以为使用drawerLayout必须用到Fragment&#xff0c;其实这是错误的&#xff0c;使用Fragment是因为在侧滑菜单被点击的时候&#xff0c;主内容区如果内容比较复杂&#xff0c;用Fragment去填充会更容易&#xff0c;如果你的主内容区只是一个简单的字符串&#xff0c;只想在不同菜单点击的时候更新一下字符串的内容&#xff0c;我觉得没必要用Fragment。我这边用Fragment所做的就是更新字符串内容这么简单。


三.源码下载

点击下载源码


四.相关文章:

单独写的一个DrawerLayout的demo

带你实现开发者头条(一) 启动页实现
带你实现开发者头条(二) 实现左滑菜单
带你实现开发者头条APP(三) 首页实现
带你实现开发者头条APP(四) 首页优化(加入design包)
带你实现开发者头条APP(五)–RecyclerView下拉刷新上拉加载

推荐下自己创建的android QQ群: 202928390欢迎大家的加入.

如果你想第一时间看我们的后期文章&#xff0c;扫码关注公众号&#xff0c;每周不定期推送Android开发实战教程文章&#xff0c;你还等什么&#xff0c;赶快关注吧&#xff0c;学好技术&#xff0c;&#xff0c;出任ceo&#xff0c;赢取白富美。。。。。。。。。。

Android开发666 - 安卓开发技术分享
扫描二维码加关注


推荐阅读
  • 在一对一直播源码使用过程中,有时会出现软键盘切换闪屏问题,就是当切换表情的时候屏幕会跳动,因此要对一对一直播源码表情面板无缝切换进行优化。 ... [详细]
  • Android开发实现的计时器功能示例
    本文分享了Android开发实现的计时器功能示例,包括效果图、布局和按钮的使用。通过使用Chronometer控件,可以实现计时器功能。该示例适用于Android平台,供开发者参考。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • 本文详细介绍了MySQL表分区的创建、增加和删除方法,包括查看分区数据量和全库数据量的方法。欢迎大家阅读并给予点评。 ... [详细]
  • Oracle seg,V$TEMPSEG_USAGE与Oracle排序的关系及使用方法
    本文介绍了Oracle seg,V$TEMPSEG_USAGE与Oracle排序之间的关系,V$TEMPSEG_USAGE是V_$SORT_USAGE的同义词,通过查询dba_objects和dba_synonyms视图可以了解到它们的详细信息。同时,还探讨了V$TEMPSEG_USAGE的使用方法。 ... [详细]
  • 在Xamarin XAML语言中如何在页面级别构建ControlTemplate控件模板
    本文介绍了在Xamarin XAML语言中如何在页面级别构建ControlTemplate控件模板的方法和步骤,包括将ResourceDictionary添加到页面中以及在ResourceDictionary中实现模板的构建。通过本文的阅读,读者可以了解到在Xamarin XAML语言中构建控件模板的具体操作步骤和语法形式。 ... [详细]
  • 本文介绍了使用cacti监控mssql 2005运行资源情况的操作步骤,包括安装必要的工具和驱动,测试mssql的连接,配置监控脚本等。通过php连接mssql来获取SQL 2005性能计算器的值,实现对mssql的监控。详细的操作步骤和代码请参考附件。 ... [详细]
  • 突破MIUI14限制,自定义胶囊图标、大图标样式,支持任意APP
    本文介绍了如何突破MIUI14的限制,实现自定义胶囊图标和大图标样式,并支持任意APP。需要一定的动手能力和主题设计师账号权限或者会主题pojie。详细步骤包括应用包名获取、素材制作和封包获取等。 ... [详细]
  • 本文介绍了在Mac上安装Xamarin并使用Windows上的VS开发iOS app的方法,包括所需的安装环境和软件,以及使用Xamarin.iOS进行开发的步骤。通过这种方法,即使没有Mac或者安装苹果系统,程序员们也能轻松开发iOS app。 ... [详细]
  • 本文讨论了如何使用Web.Config进行自定义配置节的配置转换。作者提到,他将msbuild设置为详细模式,但转换却忽略了带有替换转换的自定义部分的存在。 ... [详细]
  • 带添加按钮的GridView,item的删除事件
    先上图片效果;gridView无数据时显示添加按钮,有数据时,第一格显示添加按钮,后面显示数据:布局文件:addr_manage.xml<?xmlve ... [详细]
  • 本文提供了关于数据库设计的建议和注意事项,包括字段类型选择、命名规则、日期的加入、索引的使用、主键的选择、NULL处理、网络带宽消耗的减少、事务粒度的控制等方面的建议。同时还介绍了使用Window Functions进行数据处理的方法。通过遵循这些建议,可以提高数据库的性能和可维护性。 ... [详细]
  • 在加载一个第三方厂商的dll文件时,提示“找不到指定模块,加载失败”。由于缺乏必要的技术支持,百思不得期间。后来发现一个有用的工具 ... [详细]
  • 开发笔记:(002)spring容器中bean初始化销毁时执行的方法及其3种实现方式
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了(002)spring容器中bean初始化销毁时执行的方法及其3种实现方式相关的知识,希望对你有一定的参考价值。 ... [详细]
  • 知识图谱表示概念:知识图谱是由一些相互连接的实体和他们的属性构成的。换句话说,知识图谱是由一条条知识组成,每条知识表示为一个SPO三元组(Subject-Predicate-Obj ... [详细]
author-avatar
不分手得恋爱假的_457
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有